/**
基础
 */
.cursor-pointer{
    cursor: pointer;
}

.hover-color-primary:hover{
    color: #1cbbb4;
}

.light{
    background-color:#f3f4f9
}
.dark{

}
.dark .bg-white {
    background-color: black;
    color: white;
}
.dark .bg-black {
    background-color: white;
    color: darkGray;
}

.bg-img {
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}

.bg-mask {
    background-color: black;
    position: relative;
}

.bg-mask::after {
    content: "";
    border-radius: inherit;
    width: 100%;
    height: 100%;
    display: block;
    background-color: rgba(0, 0, 0, 0.4);
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    top: 0;
}

.bg-mask view,
.bg-mask cover-view {
    z-index: 5;
    position: relative;
}

/* flex布局 */

.flex {
    display: flex;
}

.basis-xs {
    flex-basis: 20%;
}

.basis-sm {
    flex-basis: 40%;
}

.basis-df {
    flex-basis: 50%;
}

.basis-lg {
    flex-basis: 60%;
}

.basis-xl {
    flex-basis: 80%;
}

.basis-xxl {
    flex-basis: 100%;
}

.flex-sub {
    flex: 1;
}

.flex-twice {
    flex: 2;
}

.flex-treble {
    flex: 3;
}

.flex-column {
    flex-direction: column;
}

.flex-row {
    flex-direction: row;
}

.flex-wrap {
    flex-wrap: wrap;
}

.align-start {
    align-items: flex-start;
}

.align-end {
    align-items: flex-end;
}

.align-center {
    align-items: center;
}

.align-stretch {
    align-items: stretch;
}

.self-start {
    align-self: flex-start;
}

.self-center {
    align-self: flex-center;
}

.self-end {
    align-self: flex-end;
}

.self-stretch {
    align-self: stretch;
}

.align-stretch {
    align-items: stretch;
}

.justify-start {
    justify-content: flex-start;
}

.justify-end {
    justify-content: flex-end;
}

.justify-center {
    justify-content: center;
}

.justify-between {
    justify-content: space-between;
}

.justify-around {
    justify-content: space-around;
}



/* 内外边距 */

.margin-0 {
    margin: 0;
}

.margin-xs {
    margin: 10px;
}

.margin-sm {
    margin: 20px;
}

.margin {
    margin: 30px;
}

.margin-lg {
    margin: 40px;
}

.margin-xl {
    margin: 50px;
}

.margin-xxl {
    margin: 60px;
}

.margin-top-xs {
    margin-top: 10px;
}

.margin-top-sm {
    margin-top: 20px;
}

.margin-top {
    margin-top: 30px;
}

.margin-top-lg {
    margin-top: 40px;
}

.margin-top-xl {
    margin-top: 50px;
}

.margin-top-xxl {
    margin-top: 60px;
}

.margin-right-xxs {
    margin-right: 5px;
}
.margin-right-xs {
    margin-right: 10px;
}

.margin-right-sm {
    margin-right: 20px;
}

.margin-right {
    margin-right: 30px;
}

.margin-right-lg {
    margin-right: 40px;
}

.margin-right-xl {
    margin-right: 50px;
}

.margin-right-xxl {
    margin-right: 60px;
}

.margin-bottom-xs {
    margin-bottom: 10px;
}

.margin-bottom-sm {
    margin-bottom: 20px;
}

.margin-bottom {
    margin-bottom: 30px;
}

.margin-bottom-lg {
    margin-bottom: 40px;
}

.margin-bottom-xl {
    margin-bottom: 50px;
}

.margin-bottom-xxl {
    margin-bottom: 60px;
}

.margin-left-xs {
    margin-left: 10px;
}

.margin-left-sm {
    margin-left: 20px;
}

.margin-left {
    margin-left: 30px;
}

.margin-left-lg {
    margin-left: 40px;
}

.margin-left-xl {
    margin-left: 50px;
}

.margin-left-xxl {
    margin-left: 60px;
}

.margin-lr-xxs {
    margin-left: 5px;
    margin-right: 5px;
}
.margin-lr-xs {
    margin-left: 10px;
    margin-right: 10px;
}

.margin-lr-sm {
    margin-left: 20px;
    margin-right: 20px;
}

.margin-lr {
    margin-left: 30px;
    margin-right: 30px;
}

.margin-lr-lg {
    margin-left: 40px;
    margin-right: 40px;
}

.margin-lr-xl {
    margin-left: 50px;
    margin-right: 50px;
}

.margin-lr-xxl {
    margin-left: 60px;
    margin-right: 60px;
}

.margin-tb-xs {
    margin-top: 10px;
    margin-bottom: 10px;
}

.margin-tb-sm {
    margin-top: 20px;
    margin-bottom: 20px;
}

.margin-tb {
    margin-top: 30px;
    margin-bottom: 30px;
}

.margin-tb-lg {
    margin-top: 40px;
    margin-bottom: 40px;
}

.margin-tb-xl {
    margin-top: 50px;
    margin-bottom: 50px;
}

.margin-tb-xxl {
    margin-top: 60px;
    margin-bottom: 60px;
}

.padding-0 {
    padding: 0;
}

.padding-xs {
    padding: 10px;
}

.padding-sm {
    padding: 20px;
}

.padding {
    padding: 30px;
}

.padding-lg {
    padding: 40px;
}

.padding-xl {
    padding: 50px;
}

.padding-xxl {
    padding: 60px;
}

.padding-top-xs {
    padding-top: 10px;
}

.padding-top-sm {
    padding-top: 20px;
}

.padding-top {
    padding-top: 30px;
}

.padding-top-lg {
    padding-top: 40px;
}

.padding-top-xl {
    padding-top: 50px;
}

.padding-top-xxl {
    padding-top: 64px;
}

.padding-top-sl {
    padding-top: 84px;
}

.padding-right-xs {
    padding-right: 10px;
}

.padding-right-sm {
    padding-right: 20px;
}

.padding-right {
    padding-right: 30px;
}

.padding-right-lg {
    padding-right: 40px;
}

.padding-right-xl {
    padding-right: 50px;
}

.padding-bottom-xs {
    padding-bottom: 10px;
}

.padding-bottom-sm {
    padding-bottom: 20px;
}

.padding-bottom {
    padding-bottom: 30px;
}

.padding-bottom-lg {
    padding-bottom: 40px;
}

.padding-bottom-xl {
    padding-bottom: 50px;
}

.padding-bottom-xxl {
    padding-bottom: 60px;
}

.padding-left-xs {
    padding-left: 10px;
}

.padding-left-sm {
    padding-left: 20px;
}

.padding-left {
    padding-left: 30px;
}

.padding-left-lg {
    padding-left: 40px;
}

.padding-left-xl {
    padding-left: 50px;
}

.padding-left-xxl {
    padding-left: 60px;
}

.padding-lr-xs {
    padding-left: 10px;
    padding-right: 10px;
}

.padding-lr-sm {
    padding-left: 20px;
    padding-right: 20px;
}

.padding-lr {
    padding-left: 30px;
    padding-right: 30px;
}

.padding-lr-lg {
    padding-left: 40px;
    padding-right: 40px;
}

.padding-lr-xl {
    padding-left: 50px;
    padding-right: 50px;
}

.padding-lr-xxl {
    padding-left: 50px;
    padding-right: 50px;
}

.padding-tb-xs {
    padding-top: 10px;
    padding-bottom: 10px;
}

.padding-tb-sm {
    padding-top: 20px;
    padding-bottom: 20px;
}

.padding-tb {
    padding-top: 30px;
    padding-bottom: 30px;
}

.padding-tb-lg {
    padding-top: 40px;
    padding-bottom: 40px;
}

.padding-tb-xl {
    padding-top: 50px;
    padding-bottom: 50px;
}

.padding-tb-xxl {
    padding-top: 50px;
    padding-bottom: 50px;
}

/* 圆角样式 */
.round {
    border-radius: 5000px;
}

.radius {
    border-radius: 8px;
}

.radius-top {
    border-radius: 8px 8px 0 0;
}

.radius-bottom {
    border-radius: 0 0 8px 8px;
}

.radius-top-left {
    border-radius: 8px 0 8px 0;
}

.radius-top-right {
    border-radius: 0 8px 0 8px;
}

.radius-df {
    border-radius: 16px;
}

.radius-df-top {
    border-radius: 16px 16px 0 0;
}

.radius-df-bottom {
    border-radius: 0 0 16px 16px;
}

.radius-df-top-left {
    border-radius: 16px 0 16px 0;
}

.radius-df-top-right {
    border-radius: 0 16px 0 16px;
}

.radius-lg {
    border-radius: 24px;
}

.radius-lg-top {
    border-radius: 24px 24px 0 0;
}

.radius-lg-bottom {
    border-radius: 0 0 24px 24px;
}

.radius-lg-top-left {
    border-radius: 24px 0 24px 0;
}

.radius-lg-top-right {
    border-radius: 0 24px 0 24px;
}

.radius-xl {
    border-radius: 32px;
}

.radius-xl-top {
    border-radius: 32px 32px 0 0;
}

.radius-xl-bottom {
    border-radius: 0 0 32px 32px;
}

.radius-xl-top-left {
    border-radius: 32px 0 32px 0;
}

.radius-xl-top-right {
    border-radius: 0 32px 0 32px;
}




/* 背景色 */

.bg-red {
    background-color:red;
    color: white;
}

.bg-orange {
    background-color: orange;
    color: white;
}

.bg-yellow {
    background-color: yellow;
    color: white;
}

.bg-olive {
    background-color: olive;
    color: white;
}

.bg-green {
    background-color: green;
    color: white;
}

.bg-cyan {
    background-color: cyan;
    color: white;
}

.bg-blue {
    background-color: blue;
    color: white;
}

.bg-purple {
    background-color: purple;
    color: white;
}



.bg-pink {
    background-color: pink;
    color: white;
}

.bg-brown {
    background-color: brown;
    color: white;
}

.bg-grey {
    background-color: grey;
    color: white;
}

.bg-gray {
    background-color: #f0f0f0;
    color: black;
}

.bg-black {
    background-color: black;
    color: white;
}

.bg-white {
    background-color: white;
    color: darkGray;
}



/**
文本
 */


/* ==================
          文本
 ==================== */
.text-xxs {
    font-size: 16px;
}
.text-xs {
    font-size: 20px;
}

.text-sm {
    font-size: 24px;
}

.text-df {
    font-size: 28px;
}

.text-lg {
    font-size: 32px;
}

.text-xl {
    font-size: 36px;
}

.text-xxl {
    font-size: 44px;
}

.text-sl {
    font-size: 80px;
}

.text-xsl {
    font-size: 120px;
}

.text-Abc {
    text-transform: Capitalize;
}

.text-ABC {
    text-transform: Uppercase;
}

.text-abc {
    text-transform: Lowercase;
}

.text-price::before {
    content: "¥";
    font-size: 80%;
    margin-right: 4px;
}
.text-break-all{
    word-break:break-all;
}
.text-cut {
    text-overflow: ellipsis;
    white-space: nowrap;
    overflow: hidden;
}
.text-cut-2 {
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    overflow: hidden;
    word-break: break-all;
}
.text-bold {
    font-weight: bold;
}

.text-center {
    text-align: center;
}

.text-content {
    line-height: 1.6;
}

.text-left {
    text-align: left;
}

.text-right {
    text-align: right;
}

.text-red,
.line-red,
.lines-red {
    color: #e54d42;
}

.text-orange,
.line-orange,
.lines-orange {
    color: #f37b1d;
}

.text-yellow,
.line-yellow,
.lines-yellow {
    color: #fbbd08;
}

.text-olive,
.line-olive,
.lines-olive {
    color: #8dc63f;
}

.text-green,
.line-green,
.lines-green {
    color: #39b54a;
}

.text-cyan,
.line-cyan,
.lines-cyan {
    color: #1cbbb4;
}

.text-blue,
.line-blue,
.lines-blue {
    color: #0081ff;
}

.text-purple,
.line-purple,
.lines-purple {
    color: #6739b6;
}

.text-mauve,
.line-mauve,
.lines-mauve {
    color: #9c26b0;
}

.text-pink,
.line-pink,
.lines-pink {
    color: #e03997;
}

.text-brown,
.line-brown,
.lines-brown {
    color: #a5673f;
}

.text-grey,
.line-grey,
.lines-grey {
    color: #8799a3;
}

.text-gray,
.line-gray,
.lines-gray {
    color: #aaaaaa;
}

.text-black,
.line-black,
.lines-black {
    color: #333333;
}

.text-white,
.line-white,
.lines-white {
    color: #ffffff;
}

/**
操作条
 */

.cu-bar {
    display: flex;
    position: relative;
    align-items: center;
    min-height: 100px;
    justify-content: space-between;
}

.cu-bar .action {
    display: flex;
    align-items: center;
    height: 100%;
    justify-content: center;
    max-width: 100%;
}

.cu-bar .action.border-title {
    position: relative;
    top: -10px;
}

.cu-bar .action.border-title text[class*="bg-"]:last-child {
    position: absolute;
    bottom: -0.5rem;
    min-width: 2rem;
    height: 6px;
    left: 0;
}

.cu-bar .action.sub-title {
    position: relative;
    top: -0.2rem;
}

.cu-bar .action.sub-title text {
    position: relative;
    z-index: 1;
}

.cu-bar .action.sub-title text[class*="bg-"]:last-child {
    position: absolute;
    display: inline-block;
    bottom: -0.2rem;
    border-radius: 6px;
    width: 100%;
    height: 0.6rem;
    left: 0.6rem;
    opacity: 0.3;
    z-index: 0;
}

.cu-bar .action.sub-title text[class*="text-"]:last-child {
    position: absolute;
    display: inline-block;
    bottom: -0.7rem;
    left: 0.5rem;
    opacity: 0.2;
    z-index: 0;
    text-align: right;
    font-weight: 900;
    font-size: 36px;
}

.cu-bar.justify-center .action.border-title text:last-child,
.cu-bar.justify-center .action.sub-title text:last-child {
    left: 0;
    right: 0;
    margin: auto;
    text-align: center;
}

.cu-bar .action:first-child {
    margin-left: 30px;
    font-size: 30px;
}

.cu-bar .action text.text-cut {
    text-align: left;
    width: 100%;
}

.cu-bar .cu-avatar:first-child {
    margin-left: 20px;
}

.cu-bar .action:first-child>text[class*="cuIcon-"] {
    margin-left: -0.3em;
    margin-right: 0.3em;
}

.cu-bar .action:last-child {
    margin-right: 30px;
}

.cu-bar .action>text[class*="cuIcon-"],
.cu-bar .action>view[class*="cuIcon-"] {
    font-size: 36px;
}

.cu-bar .action>text[class*="cuIcon-"]+text[class*="cuIcon-"] {
    margin-left: 0.5em;
}

.cu-bar .content {
    position: absolute;
    text-align: center;
    width: calc(100% - 340px);
    left: 0;
    right: 0;
    bottom: 0;
    top: 0;
    margin: auto;
    height: 60px;
    font-size: 32px;
    line-height: 60px;
    cursor: none;
    pointer-events: none;
    text-overflow: ellipsis;
    white-space: nowrap;
    overflow: hidden;
}

.cu-bar.ios .content {
    bottom: 7px;
    height: 30px;
    font-size: 32px;
    line-height: 30px;
}

.cu-bar.btn-group {
    justify-content: space-around;
}

.cu-bar.btn-group button {
    padding: 20px 32px;
}

.cu-bar.btn-group button {
    flex: 1;
    margin: 0 20px;
    max-width: 50%;
}

.cu-bar .search-form {
    background-color: #f5f5f5;
    line-height: 64px;
    height: 64px;
    font-size: 24px;
    color:black;
    flex: 1;
    display: flex;
    align-items: center;
    margin: 0 30px;
}

.cu-bar .search-form+.action {
    margin-right: 30px;
}

.cu-bar .search-form input {
    flex: 1;
    padding-right: 30px;
    height: 64px;
    line-height: 64px;
    font-size: 26px;
    background-color: transparent;
}

.cu-bar .search-form [class*="cuIcon-"] {
    margin: 0 0.5em 0 0.8em;
}

.cu-bar .search-form [class*="cuIcon-"]::before {
    top: 0;
}

.cu-bar.fixed,
.nav.fixed {
    position: fixed;
    width: 100%;
    top: 0;
    z-index: 1024;
    box-shadow: 0 1px 6px rgba(0, 0, 0, 0.1);
}

.cu-bar.foot {
    position: fixed;
    width: 100%;
    bottom: 0;
    z-index: 1024;
    box-shadow: 0 -1px 6px rgba(0, 0, 0, 0.1);
}

.cu-bar.tabbar {
    padding: 0;
    height: calc(100px + env(safe-area-inset-bottom) / 2);
    padding-bottom: calc(env(safe-area-inset-bottom) / 2);
}

.cu-tabbar-height {
    min-height: 100px;
    height: calc(100px + env(safe-area-inset-bottom) / 2);
}

.cu-bar.tabbar.shadow {
    box-shadow: 0 -1px 6px rgba(0, 0, 0, 0.1);
}

.cu-bar.tabbar .action {
    font-size: 22px;
    position: relative;
    flex: 1;
    text-align: center;
    padding: 0;
    display: block;
    height: auto;
    line-height: 1;
    margin: 0;
    overflow: initial;
}

.cu-bar.tabbar.shop .action {
    width: 140px;
    flex: initial;
}

.cu-bar.tabbar .action.add-action {
    position: relative;
    z-index: 2;
    padding-top: 50px;
    background-color: inherit;
}

.cu-bar.tabbar .action.add-action [class*="cuIcon-"] {
    position: absolute;
    width: 70px;
    z-index: 2;
    height: 70px;
    border-radius: 50%;
    line-height: 70px;
    font-size: 50px;
    top: -35px;
    left: 0;
    right: 0;
    margin: auto;
    padding: 0;
}

.cu-bar.tabbar .action.add-action::after {
    content: "";
    position: absolute;
    width: 100px;
    height: 100px;
    top: -50px;
    left: 0;
    right: 0;
    margin: auto;
    box-shadow: 0 -3px 8px rgba(0, 0, 0, 0.08);
    border-radius: 50px;
    background-color: inherit;
    z-index: 0;
}

.cu-bar.tabbar .action.add-action::before {
    content: "";
    position: absolute;
    width: 100px;
    height: 30px;
    bottom: 30px;
    left: 0;
    right: 0;
    margin: auto;
    background-color: inherit;
    z-index: 1;
}

.cu-bar.tabbar .btn-group {
    flex: 1;
    display: flex;
    justify-content: space-around;
    align-items: center;
    padding: 0 10px;
}

.cu-bar.tabbar button.action::after {
    border: 0;
}

.cu-bar.tabbar .action [class*="cuIcon-"] {
    width: 100px;
    position: relative;
    display: block;
    height: auto;
    margin: 0 auto 10px;
    text-align: center;
    font-size: 40px;
}

.cu-bar.tabbar .action .cuIcon-cu-image {
    margin: 0 auto;
}

.cu-bar.tabbar .action .cuIcon-cu-image image {
    width: 50px;
    height: 50px;
    display: inline-block;
}

.cu-bar.tabbar .submit {
    align-items: center;
    display: flex;
    justify-content: center;
    text-align: center;
    position: relative;
    flex: 2;
    align-self: stretch;
}

.cu-bar.tabbar .submit:last-child {
    flex: 2.6;
}

.cu-bar.tabbar .submit+.submit {
    flex: 2;
}

.cu-bar.tabbar.border .action::before {
    content: " ";
    width: 200%;
    height: 200%;
    position: absolute;
    top: 0;
    left: 0;
    transform: scale(0.5);
    transform-origin: 0 0;
    border-right: 1px solid rgba(0, 0, 0, 0.1);
    z-index: 3;
}

.cu-bar.tabbar.border .action:last-child:before {
    display: none;
}

.cu-bar.input {
    padding-right: 20px;
    background-color: white;
}

.cu-bar.input input {
    overflow: initial;
    line-height: 64px;
    height: 64px;
    min-height: 64px;
    flex: 1;
    font-size: 30px;
    margin: 0 20px;
}

.cu-bar.input .action {
    margin-left: 20px;
}

.cu-bar.input .action [class*="cuIcon-"] {
    font-size: 48px;
}

.cu-bar.input input+.action {
    margin-right: 20px;
    margin-left: 0;
}

.cu-bar.input .action:first-child [class*="cuIcon-"] {
    margin-left: 0;
}

.cu-custom {
    display: block;
    position: relative;
}

.cu-custom .cu-bar .content {
    width: calc(100% - 440px);
}


.cu-custom .cu-bar .content image {
    height: 60px;
    width: 240px;
}

.cu-custom .cu-bar {
    min-height: 0;
    padding-right: 220px;
    box-shadow: 0 0 0;
    z-index: 9999;
}

.cu-custom .cu-bar .border-custom {
    position: relative;
    background: rgba(0, 0, 0, 0.15);
    border-radius: 1000px;
    height: 30px;
}

.cu-custom .cu-bar .border-custom::after {
    content: " ";
    width: 200%;
    height: 200%;
    position: absolute;
    top: 0;
    left: 0;
    border-radius: inherit;
    transform: scale(0.5);
    transform-origin: 0 0;
    pointer-events: none;
    box-sizing: border-box;
    border: 1px solid white;
    opacity: 0.5;
}

.cu-custom .cu-bar .border-custom::before {
    content: " ";
    width: 1px;
    height: 110%;
    position: absolute;
    top: 22.5%;
    left: 0;
    right: 0;
    margin: auto;
    transform: scale(0.5);
    transform-origin: 0 0;
    pointer-events: none;
    box-sizing: border-box;
    opacity: 0.6;
    background-color: white;
}

.cu-custom .cu-bar .border-custom text {
    display: block;
    flex: 1;
    margin: auto !important;
    text-align: center;
    font-size: 34px;
}


/**
overflow
 */

.overflow-visible{
    overflow: visible;
}
.overflow-hidden{
    overflow: hidden;
}
.overflow-scroll{
    overflow: scroll;
}
.overflow-auto{
    overflow: auto;
}

/* ==================
          边框
 ==================== */

/* -- 实线 -- */

.solid,
.solid-top,
.solid-right,
.solid-bottom,
.solid-left,
.solids,
.solids-top,
.solids-right,
.solids-bottom,
.solids-left,
.dashed,
.dashed-top,
.dashed-right,
.dashed-bottom,
.dashed-left {
    position: relative;
}

.solid::after,
.solid-top::after,
.solid-right::after,
.solid-bottom::after,
.solid-left::after,
.solids::after,
.solids-top::after,
.solids-right::after,
.solids-bottom::after,
.solids-left::after,
.dashed::after,
.dashed-top::after,
.dashed-right::after,
.dashed-bottom::after,
.dashed-left::after {
    content: " ";
    width: 200%;
    height: 200%;
    position: absolute;
    top: 0;
    left: 0;
    border-radius: inherit;
    transform: scale(0.5);
    transform-origin: 0 0;
    pointer-events: none;
    box-sizing: border-box;
}

.solid::after {
    border: 1px solid rgba(0, 0, 0, 0.1);
}

.solid-top::after {
    border-top: 1px
    solid rgba(0, 0, 0, 0.1);
}

.solid-right::after {
    border-right: 1px
    solid rgba(0, 0, 0, 0.1);
}

.solid-bottom::after {
    border-bottom: 1px
    solid rgba(0, 0, 0, 0.1);
}

.solid-left::after {
    border-left: 1px
    solid rgba(0, 0, 0, 0.1);
}

.solids::after {
    border: 8px
    solid #eee;
}

.solids-top::after {
    border-top: 8px
    solid #eee;
}

.solids-right::after {
    border-right: 8px
    solid #eee;
}

.solids-bottom::after {
    border-bottom: 8px
    solid #eee;
}

.solids-left::after {
    border-left: 8px
    solid #eee;
}

/* -- 虚线 -- */

.dashed::after {
    border: 1px
    dashed #ddd;
}

.dashed-top::after {
    border-top: 1px
    dashed #ddd;
}

.dashed-right::after {
    border-right: 1px
    dashed #ddd;
}

.dashed-bottom::after {
    border-bottom: 1px
    dashed #ddd;
}

.dashed-left::after {
    border-left: 1px
    dashed #ddd;
}

/* -- 阴影 -- */

.shadow[class*='white'] {
    --ShadowSize: 0 1px
    6px
;
}

.shadow-lg {
    --ShadowSize: 0px
    40px
    100px
    0px
;
}

.shadow-warp {
    position: relative;
    box-shadow: 0 0 10px
    rgba(0, 0, 0, 0.1);
}

.shadow-warp:before,
.shadow-warp:after {
    position: absolute;
    content: "";
    top: 20px
;
    bottom: 30px
;
    left: 20px
;
    width: 50%;
    box-shadow: 0 30px
    20px
    rgba(0, 0, 0, 0.2);
    transform: rotate(-3deg);
    z-index: -1;
}

.shadow-warp:after {
    right: 20px
;
    left: auto;
    transform: rotate(3deg);
}

.shadow-blur {
    position: relative;
}

.shadow-blur::before {
    content: "";
    display: block;
    background: inherit;
    filter: blur(10px
    );
    position: absolute;
    width: 100%;
    height: 100%;
    top: 10px
;
    left: 10px
;
    z-index: -1;
    opacity: 0.4;
    transform-origin: 0 0;
    border-radius: inherit;
    transform: scale(1, 1);
}